<template>
  <div class="avue-contail" :class="{ 'avue--collapse': isCollapse }">
    <zp-batch-upload />
    <screenshot v-if="setting.screenshot"></screenshot>
    <!-- <setting></setting> -->
    <div
      class="avue-layout"
      :class="{ 'avue-layout--horizontal': isHorizontal }"
    >
      <div class="avue-sidebar">
        <!-- 左侧导航栏 -->
        <logo />
        <sidebar />
      </div>
      <div class="avue-main">
        <!-- 顶部导航栏 -->
        <top ref="top" />
        <!-- 顶部标签卡 -->
        <tags />
        <transition name="fade-scale">
          <search class="avue-view" v-show="isSearch"></search>
        </transition>
        <!-- 主体视图层 -->
        <div
          style="flex:auto;overflow-y:auto;overflow-x:hidden;"
          id="avue-view"
          v-show="!isSearch"
        >
          <keep-alive>
            <router-view
              class="avue-view"
              v-if="$route.meta.keepAlive && isRefresh"
            />
          </keep-alive>
          <router-view
            class="avue-view"
            v-if="!$route.meta.keepAlive && isRefresh"
          />
        </div>
      </div>
    </div>
  </div>
</template>

<script>
import { mapGetters } from "vuex";
import tags from "./tags";
import screenshot from "./screenshot";
// import setting from './setting';
import search from "./search";
import logo from "./logo";
import top from "./top/";
import sidebar from "./sidebar/";
import admin from "@/util/admin";
import { validatenull } from "@/util/validate";
import { calcDate } from "@/util/date.js";
import { getStore } from "@/util/store.js";

export default {
  components: {
    top,
    logo,
    tags,
    search,
    sidebar,
    // setting,
    screenshot,
  },
  name: "index",
  provide() {
    return {
      index: this,
    };
  },
  data() {
    return {
      //搜索控制
      isSearch: false,
      //刷新token锁
      refreshLock: false,
      //刷新token的时间
      refreshTime: "",
    };
  },
  created() {
    this.refreshToken();
  },
  mounted() {
    this.init();
  },
  computed: mapGetters([
    "isHorizontal",
    "setting",
    "isRefresh",
    "isLock",
    "isCollapse",
    "website",
    "menu",
  ]),
  props: [],
  methods: {
    // 屏幕检测
    init() {
      this.$store.commit("SET_SCREEN", admin.getScreen());
      window.onresize = () => {
        setTimeout(() => {
          this.$store.commit("SET_SCREEN", admin.getScreen());
        }, 0);
      };
    },
    //打开菜单
    openMenu(item = {}) {
      this.$store.dispatch("GetMenu", item.parentId).then((data) => {
        if (data.length !== 0) {
          this.$router.$avueRouter.formatRoutes(data, true);
        }
        //当点击顶部菜单做的事件
        if (!validatenull(item)) {
          let itemActive = {},
            childItemActive = 0;
          //vue-router路由
          if (item.path) {
            itemActive = item;
          } else {
            if (this.menu[childItemActive].length == 0) {
              itemActive = this.menu[childItemActive];
            } else {
              itemActive = this.menu[childItemActive].children[childItemActive];
            }
          }
          this.$store.commit("SET_MENUID", item);
          this.$router.push({
            path: this.$router.$avueRouter.getPath(
              {
                name: itemActive.label,
                src: itemActive.path,
              },
              itemActive.meta
            ),
          });
        }
      });
    },
    // 10分钟检测一次token
    refreshToken() {
      this.refreshTime = setInterval(() => {
        const token =
          getStore({
            name: "token",
            debug: true,
          }) || {};
        const date = calcDate(token.datetime, new Date().getTime());
        // 退出后,store未清,时间永远存在,导致连续刷refresh_token
        if (validatenull(token.refreshToken) || validatenull(date)) return;
        if (date.seconds >= this.website.tokenTime && !this.refreshLock) {          
          this.refreshLock = true;
          this.$store
            .dispatch("RefeshToken")
            .then(() => {
              this.refreshLock = false;
            })
            .catch(() => {
              this.refreshLock = false;
            });
        }
      }, 60000);
    },
  },
};
</script>
